/**
 * @param {number} n
 * @return {number}
 */
var cuttingRope = function (n) {
	// 初始值
	let dp = new Array(n + 1).fill(1);
	for (let i = 3; i <= n; i++) {
		// i 表示长度为总共为i
		for (let j = 1; j < i; j++) {
			// j 表示在长度为 i 时剪下的第一刀，共有 1, 2, 3, ..., i - 1中情况
			// 遍历剪下第一刀的所有情况， 得到最大值
			dp[i] = Math.max(dp[i], j * (i - j), j * dp[i - j])
		}
	}
	return dp[n];
};